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Detailed Office Action 



i. 



This action is in response to the amendment filed on May 25, 2005. 



2.. 



Claims 1-57 are pending. 



Claim Rejections - 35 USC § 103 



3. . The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
' forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary' skill in the art to which said subject ma iter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 



4. Claims 1-4, and 7-57 are rejected under 35 U.S.C. 103(a) as being 

unpatentable over Hassett et al., (hereinafter Hassett) U.S. Patent No. 
6,173,31 1 in view of Kraenzel et al., (hereinafter Kraenzel) U.S. Patent No. 
6,854,016. 



5 



As to claim 1, Hassett discloses a method of supporting multiple data stores 



(cache 220 and 270 fig. 2) for an integrated access system and identity system, 



comprising the steps of: receiving a request at said integrated (receiving 
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request from client to access to data information) access system and identity 
system (210 fig. 2), said integrated access system and identity system 
supporting a plurality of data stores (cache 220 and 270 fig. 2) (see abstract, 
fig. 2, col. 6 line 66 to col. 7 line 15), accessing based on the one or more of 
said data stores (cache 220 and 270 fig.2) via the agent for the one or more 
data stores in response to said request, and reporting information based on 
said step of accessing (transmitting a table to the caching server to identify 
which caching server agent will serve the request, see also figs.3A, 3B, col. 7 
lines 16-65). But Hassett does not explicitly teach each data store associated 
with an agent and a profiles representing configuration information for the 
data store. However, Kraenzel teaches each data store associated with an 
agent and a profiles representing configuration information for the data store 
(fig. 13) (agent 560, 563, 561 and directory 350, 212, and 351) (see col. 18, 
lines 20-67, and col.21, lines 5-25). It would have been obvious to one of 
ordinary skill in the art at the time of the invention was made to implement the ' 
teachings of Kraenzel into the computer system of Hassett to have each data 
store associated with a agent and a profiles representing configuration 
information for the data store because it would have an efficient system that 
can provide specific functions that collect a data or information that has a 
name. 

6. As to claims 2-4, Hassett discloses that the step of accessing includes reading 
data, writing data and step of reporting includes confirming a write action 
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(performing read and write operations, see col. 8 lines 14-63 and col. 9 lines 9- 
33). 

7. As to claims 7-9, Hassett discloses said plurality of data stores include 
different types of data stores, reading first data from a first data store (220 
fig. 2) 'and reading second data from a second data store (270 fig. 2) and said 
step of reporting includes translating said first data to a first format and 
translating said second data to said first format (processing a variety of data 
formats such as MIME, ASCII, see col. 9 line 61 to col. 10 line 57 and col. 12 
lines 12-67). 

8. As to claims 10-11, Hassett discloses prior to said translating, said first data is 
in a different format than said second data, said first data store is a first type of 
data store, said second data store is a second type of data store, said step of 
accessing includes reading first data from a first data store and reading second 
data from a second data store and said step of reporting includes combining 
said first data with said second data (see col. 1 2 lines 1 2-67 and col. 1 8 lines 4- 
61). 



9. As to claims 12-13, Hassett discloses said first data store is a first type of data 
store, said second data store is a second type of data store, said step of 
accessing includes multiple read and write operations to said data stores in 
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response to said request (performing read and write operations, see col. 8 lines 
• 14-63 and col.9 lines 9-33). 

10. As to claim 14, Hassett discloses determining which data stores can service a 
particular data access, creating a proxy with one or more pointers to agents for 
said data stores that can service said particular data access (selecting which 
agent will serve the client's request), and facilitating performance of said 
particular data access using said proxy (see figs. 2 and 12, col. 7 lines 5-26 and 
col. 12 lines 3-57). 

11. As to claims 15-17, Hassett discloses determining which data stores can 
service a particular data access, and communicating with agents for said data 
stores that can service said particular data access in order to perform said 
particular data access (see fig. 8, col.9 line 34 to ocl.10 line 44), said data 
stores store disjoint namespaces and each said data store stores a different 
portion of a directory (Corporate Scatch Directory, see col. 12 lines 4-67). 

12. As to claim 18, Hassett discloses method of supporting multiple data stores, 
comprising the steps of: receiving a request (receiving request from client to 
access to data information) to access one or more of a plurality of data stores 
(220 and 270 fig. 2); determining based on which data stores can service said 
request, each data store is associated with a separate agent (210 and 230 fig. 2) 
(see abstract, fig. 2, col. 6 line 66 to col. 7 line 15); accessing said data stores 
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(220 and 270 fig. 2) that can service said request by communicating with said 
associated agents and reporting information based on said step of accessing 
(transmitting a table to the caching server to identify which caching server 
agent will serve the request, see figs. 3 A, 3B, col. 7 lines 16-65). But Hassett 
does not explicitly teach each data store associated with an agent and a 
profiles representing configuration information for the data store. However, 
Kraenzel teaches each data store associated with an agent and a profiles 
representing configuration information for the data store (fig. 13) (agent 560, 
563, 561 and directory 350, 212, and 351) (see col. 18, lines 20-67, and 
col.21, lines 5-25). It would have been obvious, to one of ordinary skill in the 
art at the time of the invention was made to implement the teachings of 
Kraenzel into the computer system of Hassett to have each data store 
associated with a agent and a profiles representing configuration information 
for the data store because it would have an efficient system that can provide 
specific functions that collect a data or information that has a name. 

13. As to claims 19-20, Hassett discloses determining includes querying the 
profile (category ID) for each data store, creating a proxy (using proxy 
server) with one or more pointers to agents associated with said data stores 
that can service said request and communicating, via said proxy, with said 
data stores that can service said request (see figs.3A, 3B, col. 7 line 27 to col. 8 
line 32). 
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14. As to claims 21-22, Hassett discloses receiving, determining, creating and 
communicating are performed by a database manager (using a database 
server); and each data store is associated with a connection manager for 
communicating with said data store (see figs. 11 A, 12, col. 11 line 52 to col. 12 
line 57). 



15. As to claim 23, Hassett discloses determining includes querying the profile for 
each data store, creating a proxy with one or more pointers to agents 
associated with said data stores that can service said request, and 
communicating, via said proxy, with said data stores that can service said 
request (see col. 7 lines 27-65); receiving, determining, creating and 
communicating are performed by a database manager (using a database 
server); and each data store is associated with a connection manager for 

, communicating with said data store (see figs. 1 1 A, 12, col. 1 1 line 52 to col. 1 2 
line 57); said step of communicating is not performed by said database 
manager and each data store is associated with a collection manager for 
communicating with said data store (see col. 18 lines 4-61). 

1 6. As to claims 24-25, Hassett discloses said plurality of data stores include 
different types of data stores and step of accessing includes reading first data 
from a first data store and reading second data from a second data store and 
said step of reporting includes translating said first data to a first format and 
translating said second data to said first format, prior to said translating, said 



Application/Control Number: 09/998,908 Pag 
Art Unit: 2144 

first data is in a different format than said second data (processing a variety of 
data formats such as MIME, ASCII, see col. 9 line 61 to col. 10 line 57 and 
col. 12 lines 12-67). 

17. As to claim 26, Hassett discloses said step of accessing includes reading first 
data from a first data store and reading second data from a second data store; 
said first data store is a first type of data store and said second data store is a . 
second type of data store; and said step of reporting includes combining said 
first data with said second (see col. 12 lines 12-67 and col. 18 lines 4-61). 

18. As to claim 27, Hassett discloses steps of receiving, determining, accessing 
and reporting are performed by an Identity System (see fig. 2, col. 7 lines 9-65). 

19. As to claim 28, Hassett discloses a method of supporting multiple data stores 
(220 and 270 fig. 2), comprising the steps of: receiving a request to access one 
or more of a plurality of data stores each data store representing configuration 
information for the data store; and determining based on which data stores can 
service said request (see abstract, fig. 2, col. 6 line 66 to col. 7 line 1 5); creating 
a proxy having knowledge of which data stores can service said request, using 
said proxy to access said data stores that can service said request and reporting 
information based on said step of accessing (transmitting a table to the 
caching server to identify which caching server agent will serve the request, 
see figs. 3 A, 3B, col. 7 lines 16-65). But Hasset does not explicitly teach a 
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profile. However, kraenzel teaches a profile (see col. 18, lines 20-67, and 
col.21, lines 5-25). It would have been obvious to one of ordinary, skill in the 
art at the time of the invention was made to implement the teachings of 
Kraenzel into the computer system of Hassett to have a profile because it 
would have an efficient system that can provide specific functions that collect 
a data or information that has a name. 

20. As to claims 29-30, Hassett discloses said knowledge of which data stores can 
service said request includes maintaining a set of pointers to agents for said 
data stores that can service said request and receiving, at said proxy, a data 
operation, communicating said data operation from said proxy to data stores, 
receiving one or more results (identifying which caching server agent will 
serve the request) at said and reporting said results (using a database server, 
see figs. 11 A, 12, col. 7 lines 16-65 and col. 1 1 line 52 to col. 12 line 57). 

21. As to claims 31-32, Hassett discloses said plurality of data stores include 
different types of data stores and reading first data from a first data store and 
reading second data from a second data store, said step of reporting includes 
translating said first data to a first format and translating said second data to 
said first format, said first data is in a different format than said second data 
prior to said translating (processing a variety of data formats such as MIME, 
ASCII, see col. 9 line 61 to col. 10 line 57 and col. 12 lines 12-67). 
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22. Claims 33-53 are rejected for the same reasons set forth in claims 26-28, 31, 
32, 14, 15, 18, 23, 23, 24, 25, 27, 18, 19, 25, 27, 18, 19, 48 and 49 
respectively. 

23. As to claim 54, Hassett discloses using includes said proxy communicating 
with separate agent (using proxy server to process client's request) for each of 
said data stores that can service said request (see col. 7 lines 9-65). 

24. As to claim 55, Hassett discloses a system that supports multiple data stores, 
comprising: a set of profiles (user category Ids), each profile associated with 
one of said data stores and a set of agents, each agent associated with one of 
said data stores (220 and 270 fig. 2), a temporary proxy (210 fig.2) and a 
database manager (230 fig. 2), said database manager in communication with 
said profiles (see abstract, fig. 2, col. 6 line 66 to col. 7 line 15); said database 
manager creates said proxy in response to a request to access said data stores, 
said database manager caused said proxy to be in communication with agents 
associated with data stores that can service said request based on (transmitting 
a table to the caching server to identify which caching server agent will serve 
the request, see figs. 3 A, 3B, col. 7 lines 16-65). But Hasset does not 
explicitly teach a profile. However, kraenzel teaches a profile (see col. 18, 
lines 20-67, and col.21, lines 5-25). It would have been obvious to one of 
ordinary skill in the art at the time of the invention was made to implement the 
teachings of Kraenzel into the computer system of Hassett to have a profile 
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because it would have an efficient system that can provide specific functions 
that collect a data or information that has a name. 



25. As to claims 56-57, Hassett discloses said database manager is part of an 
integrated Identity System and Access System and said multiple data stores 
include different types of data stores (processing a variety of data formats 
such as MIME, ASCII, see col. 9 line 61 to col. 10 line 57 and col. 12 lines 12- 
67). 

26. Claims 5 and 6 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
Hassett et al., (hereinafter Hassett) U.S. Patent No. 6,173,311, and Kraenzel et 
al., (hereinafter Kraenzel) U.S. Patent No. 6,854,016. in view of Brown et al., 
(hereinafter Brown) U.S. Patent No. 6,678,733. 

27. As to claim 5, Hassett does not explicitly teach plurality of data stores 
includes LDA.P directories. However, Brown discloses Lightweight Directory 
Access Protocol (LDAP) directories (see col. 9, line 40 to col. 10, line 10). It 
would have been obvious to one of ordinary skill in the art at the time of the 
invention was made to implement the teachings of Brown into the computer 
system of Hassett to have plurality of data stores includes LDAP directories 
because it would have made it possible for almost any application ainning on 
virtually any computer platform to obtain directory information such as email 
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address and public keys, and need not worry about the type of server hosting 
the directory. 

28. As to claim 6, Hassett does not explicitly teach plurality of data stores 
includes at least one Structured Query Language (SQL) database. However, 
Brown teaches data stores include at least one SQL database (see col. 9, line 
40 to col. 10, line 10). It would have been obvious to one of ordinary skill in 
the art at the time of the invention was made to implement the teachings of 
Brown into the computer system of Hassett to have plurality of data stores 
includes at least one SQL database because it would have provided a favorite 
query language for database management systems running on minicomputers 
and mainframes, and it also supports distributed databases (databases that are 
spread out over several computer systems). 

Conclusion 

29. Applicant's amendment necessitated the new ground(s) of rejection presented 
in this Office action. Accordingly, THIS ACTION IS MADE FINAL. See MPEP 

§ 706.07(a). Applicant is reminded of the extension of time policy as set forth in 37 
CFR 1.136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within 
TWO MONTHS of the mailing date of this final action and the advisory action is not 
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mailed until after the end of the THREE-MONTH shortened statutory period, then the 
shortened statutory period will expire on the date the advisory action is mailed, and any 
extension fee pursuant to 37 CFR 1.136(a) will be calculated from the mailing date of the 
advisory action. In no event, however, will the statutory period for reply expire later than 
SIX MONTHS from the date of this final action. 

30. Any inquiries concerning this communication or earlier communications from 
the examiner should be directed to Tammy T. Nguyen who may be reached via 
telephone at (571) 272-3929. The examiner can normally be reached Monday through 
Friday between 8:00 a.m. and 5:00 p.m. eastern standard time.' 

If you need to send the Examiner, a facsimile transmission regarding this 
instant application, please send it to (703) 872-9306. If attempts to reach the examiner 
by telephone are unsuccessful, the Examiner's Supervisor, David Wiley, may be reached 
at (571) 272-3923. 

TTN 

August 10, 2005 
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